package oj;

import java.util.*;

//宝石与石头：给你一个字符串 jewels 代表石头中宝石的类型，另有一个字符串 stones 代表你拥有的石头。 stones 中每个字符代表了一种你拥有的石头的类型，你想知道你拥有的石头中有多少是宝石。字母区分大小写，因此 "a" 和 "A" 是不同类型的石头。
public class Solution_771 {
    public int numJewelsInStones(String jewels, String stones) {
        //先构建宝石集合
        TreeSet<Character> jewelSet = new TreeSet<>();
        //将每一种宝石都放到 Set 中
        //先遍历 jewels String -> char
        //有两种方法 ：1，toCharArray()    2.s.charAt(i)
        for(char ch : jewels.toCharArray()){
            jewelSet.add(ch);
        }
        //拿着每一块石头去宝石集合中搜索
        int ans = 0;
        for(char sto : stones.toCharArray()){
            if(jewelSet.contains(sto)){
                ans++;
            }
        }
        return ans;
    }
}
